Second Level Cache (EHCache, OSCache)

Java Technologies - হাইবারনেট (Hibernate) Hibernate Caching |
162
162

Hibernate একটি Object-Relational Mapping (ORM) ফ্রেমওয়ার্ক যা ডেটাবেসের সঙ্গে Java objects এর ইন্টারঅ্যাকশন সহজ করে। Hibernate বিভিন্ন ধরণের ক্যাশিং মেকানিজম সাপোর্ট করে, যার মধ্যে Second Level Cache খুবই গুরুত্বপূর্ণ। Second Level Cache হল একটি ক্যাশ স্তর যা SessionFactory এর উপর ভিত্তি করে কাজ করে এবং এটি Hibernate ক্যাশিং পদ্ধতির মধ্যে একটি অতিরিক্ত স্তর সরবরাহ করে।

Second Level Cache: ধারণা

  • First Level Cache: Hibernate এর প্রথম স্তরের ক্যাশ যা Session অবজেক্টে থাকে এবং এটি session-per-request প্যাটার্নে কাজ করে। একটি সেশন বন্ধ হওয়ার পর, ক্যাশের ডেটা ফ্রি হয়ে যায়।
  • Second Level Cache: এটি SessionFactory-এর সাথে সম্পর্কিত একটি ক্যাশ, যা sessions এর মধ্যে শেয়ার করা হয় এবং ডেটাবেসে একাধিক কল থেকে প্রাপ্ত ডেটা ক্যাশ করে রাখতে সহায়তা করে।

Second Level Cache মূলত ডেটাবেস থেকে বারবার ডেটা পুনরুদ্ধার করার পরিবর্তে ডেটার একটি কপি ক্যাশে রেখে ব্যবহৃত হয়, যা অ্যাপ্লিকেশনের পারফরম্যান্স উন্নত করতে সাহায্য করে।


Second Level Cache ব্যবহারের সুবিধা:

  1. Performance Improvement:
    • Second Level Cache, ডেটাবেস থেকে একাধিক বার একই ডেটা রিকুয়েস্ট করার পরিবর্তে ক্যাশে সঞ্চিত ডেটা সরবরাহ করে, যার ফলে ডেটাবেস লোড কমে এবং পারফরম্যান্স বৃদ্ধি পায়।
  2. Reduced Database Access:
    • যখন ডেটা ক্যাশে থাকে, তখন একই ডেটা বারবার ডেটাবেসে রিকুয়েস্ট করার দরকার হয় না, যা ডেটাবেসের উপর চাপ কমায়।
  3. Data Sharing Between Sessions:
    • Second Level Cache এর মাধ্যমে একাধিক সেশনের মধ্যে ডেটা শেয়ার করা যায়, যা অ্যাপ্লিকেশন জুড়ে ডেটা অ্যাক্সেসের সঠিকতা এবং দক্ষতা বাড়ায়।

Second Level Cache এর জন্য Popular Implementations

Hibernate দুইটি জনপ্রিয় ক্যাশিং প্রোভাইডার সাপোর্ট করে:

  1. EHCache
  2. OSCache

এই ক্যাশিং টুলস Hibernate এর Second Level Cache এর জন্য ব্যবহৃত হয়।


1. EHCache

EHCache একটি ওপেন সোর্স ক্যাশিং লাইব্রেরি যা second level cache হিসাবে খুবই জনপ্রিয় এবং Hibernate এর সাথে সহজে ইন্টিগ্রেট করা যায়। এটি Java এর জন্য একটি শক্তিশালী ক্যাশিং সিস্টেম সরবরাহ করে, এবং এটি ডেটা ক্যাশিং, object caching, query caching, এবং distributed caching এর জন্য ব্যবহৃত হয়।

EHCache Configuration:

  1. Maven Dependency:
<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-ehcache</artifactId>
    <version>5.4.32.Final</version> <!-- Or the latest version -->
</dependency>

<dependency>
    <groupId>net.sf.ehcache</groupId>
    <artifactId>ehcache</artifactId>
    <version>2.10.0</version> <!-- Or the latest version -->
</dependency>
  1. hibernate.cfg.xml Configuration:
<hibernate-configuration>
    <session-factory>
        <!-- Enable second level cache -->
        <property name="hibernate.cache.use_second_level_cache">true</property>
        <property name="hibernate.cache.region.factory_class">
            org.hibernate.cache.ehcache.EhCacheRegionFactory
        </property>
        <property name="hibernate.cache.provider_configuration_file_resource_path">
            /ehcache.xml
        </property>
        <property name="hibernate.cache.use_query_cache">true</property>
    </session-factory>
</hibernate-configuration>
  1. ehcache.xml Configuration:
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://ehcache.org/ehcache.xsd
             http://ehcache.org/schema/ehcache http://ehcache.org/schema/ehcache.xsd"
         xmlns="http://ehcache.org/schema/ehcache">

    <cache name="com.example.MyEntity"
           maxEntriesLocalHeap="1000"
           eternal="false"
           timeToIdleSeconds="600"
           timeToLiveSeconds="1200"
           overflowToDisk="false"
           statistics="true">
    </cache>
</ehcache>

ব্যাখ্যা:

  • Hibernate এর মধ্যে hibernate.cache.region.factory_class সেটিংয়ে EHCache এর জন্য EhCacheRegionFactory নির্ধারণ করা হয়েছে।
  • EHCache ক্যাশ কনফিগারেশন ehcache.xml ফাইলে নির্ধারিত হয়েছে যেখানে ডেটা ক্যাশিং সম্পর্কিত সেটিংস যেমন maximum entries, expiry time ইত্যাদি কনফিগার করা হয়েছে।

2. OSCache

OSCache একটি open-source ক্যাশিং লাইব্রেরি যা Hibernate এর second level cache হিসাবে ব্যবহৃত হতে পারে। এটি হাই- পারফরম্যান্স ক্যাশিং সমাধান সরবরাহ করে এবং in-memory এবং disk-based ক্যাশিং উভয় সাপোর্ট করে।

OSCache Configuration:

  1. Maven Dependency:
<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-oscache</artifactId>
    <version>3.2.6.ga</version> <!-- Or the latest version -->
</dependency>

<dependency>
    <groupId>net.sf.oscache</groupId>
    <artifactId>oscache</artifactId>
    <version>2.4.1</version> <!-- Or the latest version -->
</dependency>
  1. hibernate.cfg.xml Configuration:
<hibernate-configuration>
    <session-factory>
        <!-- Enable second level cache -->
        <property name="hibernate.cache.use_second_level_cache">true</property>
        <property name="hibernate.cache.region.factory_class">
            org.hibernate.cache.oscache.OSCacheProvider
        </property>
        <property name="hibernate.cache.use_query_cache">true</property>
    </session-factory>
</hibernate-configuration>
  1. OSCache Configuration:
<cache>
    <name>com.example.MyEntity</name>
    <maxElementsInMemory>1000</maxElementsInMemory>
    <eternal>false</eternal>
    <timeToLive>600</timeToLive>
    <timeToIdle>300</timeToIdle>
</cache>

ব্যাখ্যা:

  • OSCache এর জন্য ক্যাশ কনফিগারেশন XML ফাইলে নির্ধারিত হয়। এটি টেবিল বা ক্লাসের উপর নির্ভর করে maxElementsInMemory, timeToLive, timeToIdle ইত্যাদি কনফিগারেশন সেট করতে পারে।
  • hibernate.cache.region.factory_classOSCacheProvider ব্যবহৃত হয়েছে।

Third-party Libraries Comparison: EHCache vs OSCache

FeatureEHCacheOSCache
PerformanceHigh performance, especially for large-scale applications.Good for general use but less efficient for large-scale apps.
Ease of UseEasy to integrate and configure with Hibernate.Requires some setup and may need more maintenance.
Memory ManagementSupports in-memory and disk-based storage, fine-tuned eviction policies.Primarily in-memory with basic eviction policies.
Distributed CachingSupports distributed caching and replication (via Terracotta integration).Limited support for distributed caching.
MaturityWidely adopted, actively maintained.Older, less actively maintained.
IntegrationSeamless with Hibernate and popular frameworks.Can be used with Hibernate but requires more configuration.

Hibernate Second Level Cache এর মাধ্যমে ডেটাবেস অ্যাক্সেস অপটিমাইজ করা হয় এবং ডেটাবেসের উপর চাপ কমানো হয়। EHCache এবং OSCache দুটি জনপ্রিয় ক্যাশিং প্রোভাইডার যা Hibernate এর সেকেন্ড লেভেল ক্যাশের জন্য ব্যবহৃত হয়। EHCache একটি শক্তিশালী এবং কার্যকরী ক্যাশিং সিস্টেম সরবরাহ করে, এবং এটি distributed caching এর জন্য এক্সটেনশন সরবরাহ করে, যা বড় আর্কিটেকচারগুলির জন্য উপযুক্ত। অন্যদিকে, OSCache সিম্পল ক্যাশিং সমাধান সরবরাহ করে, কিন্তু এতে distributed caching এর সমর্থন কম।

অতএব, আপনার প্রয়োজনের উপর নির্ভর করে আপনি EHCache বা OSCache এর মধ্যে যেকোনো একটি ক্যাশিং সিস্টেম নির্বাচন করতে পারেন।

Content added By
Promotion